package com.ruoyi.system.mapper;

import java.util.List;
import java.util.Map;
import org.apache.ibatis.annotations.Param;
import com.ruoyi.system.domain.Leaveapply;

/**
 * 请假Mapper接口
 * 
 * @author shenzhanwang
 * @date 2022-04-02
 */
public interface LeaveapplyMapper 
{
    /**
     * 查询请假
     * 
     * @param id 请假主键
     * @return 请假
     */
    public Leaveapply selectLeaveapplyById(Long id);

    /**
     * 查询请假列表
     * 
     * @param leaveapply 请假
     * @return 请假集合
     */
    public List<Leaveapply> selectLeaveapplyList(Leaveapply leaveapply);

    /**
     * 新增请假
     * 
     * @param leaveapply 请假
     * @return 结果
     */
    public int insertLeaveapply(Leaveapply leaveapply);

    /**
     * 修改请假
     * 
     * @param leaveapply 请假
     * @return 结果
     */
    public int updateLeaveapply(Leaveapply leaveapply);

    /**
     * 删除请假
     * 
     * @param id 请假主键
     * @return 结果
     */
    public int deleteLeaveapplyById(Long id);

    /**
     * 批量删除请假
     * 
     * @param ids 需要删除的数据主键集合
     * @return 结果
     */
    public int deleteLeaveapplyByIds(String[] ids);

    /**
     * 获取请假总数
     */
    public int selectTotalCount();

    /**
     * 获取最近一个月请假数
     */
    public int selectLastMonthCount();

    /**
     * 获取最近一个月审批数
     */
    public int selectApprovalCount();

    /**
     * 获取按天统计的请假数据
     */
    public List<Map<String, Object>> selectDailyChartData();

    /**
     * 获取按月统计的请假数据
     */
    public List<Map<String, Object>> selectMonthlyChartData();

    /**
     * 获取按年统计的请假数据
     */
    public List<Map<String, Object>> selectYearlyChartData();

    /**
     * 获取用户待办任务数
     * @param userId 用户ID，如果为null则查询所有
     * @return 待办任务数
     */
    public int selectPendingTaskCount(String userId);

    /**
     * 获取上个月待办任务数（用于计算环比）
     * @param userId 用户ID，如果为null则查询所有
     * @return 上个月待办任务数
     */
    public int selectLastMonthPendingTaskCount(String userId);

    /**
     * 查询最近的请假申请列表
     * @param deptId 部门ID，如果为null则查询所有部门
     * @param userId 用户ID，如果为null则不按用户过滤
     * @return 请假申请列表
     */
    public List<Map<String, Object>> selectRecentLeaveApplyList(@Param("deptId") Long deptId, @Param("userId") String userId);
}
